<html>

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>我还是帅</title>
    <style>
        body {
            background: #f2f4f7 !important;
            display: flex;
            /* 给body加一个弹性布局 控制子元素位置*/
            justify-content: center;
            /* 子元素 左右居中 */
            align-items: center;
            /* 子元素上下居中 */
        }

        body .login {
            width: 900px;
            height: 584px;
            background: #fff;
        }

        @media(max-width:768px) {

            /* 手机端 login宽高100% */
            body .login {
                width: 100vw;
                height: 100vh;
            }
        }

        /* 继承父元素login的宽高 */
        .container {
            width: 100%;
            height: 100%;
            /* 怪异盒子模型 */
            box-sizing: border-box;
            /* 上下左右都向内挤占50px */
            padding: 50px;
        }

        /* 子选择器 只选择 .container的子元素row */
        #container>.row {
            /* calc会计算距离 写法左侧像素减右侧像素 减号两侧一定要加空格 */
            width: calc(100% - 100px);
            height: 100%;
            margin: auto;
        }
    </style>
</head>

<body>
    <div class="login shadow rounded"><i class="bi bi-reply"></i>
        <div class="container">
            <!-- 使用栅格系统进行左右布局 -->
            <!-- 1. 电脑端 左侧2/3 右侧1/3 -->
            <!-- 2. 移动端 左侧100%显示 右侧不显示 -->
            <!-- bootstrap栅格系统行(有12列) 类row让子元素同一行显示 -->
            <div class="row">
                <!-- col-6优先级太高了 导致col-xs-12没生效(手机屏100%宽没法生效) -->
                <!-- 改为col-md-8 电脑端一行左侧占8/12 右侧col-md-4占4/12 -->
                <!-- 当手机端时 col-md系列样式失效 col-xs-12生效 第一个div宽度12/12 -->
                <div class="col-md-5 offset-md-1 col-xs-12">
                    <h4>用户登录</h4>
                    <div class="input-group mb-3">
                        <span class="input-group-text text-muted" id="basic-addon1"><i class="bi bi-tablet"></i></span>
                        <input type="text" id="username" class="form-control" placeholder="用户名/手机号" aria-label="用户名/手机号"
                            aria-describedby="basic-addon1" />
                    </div>
                    <div class="input-group mb-3">
                        <span class="input-group-text text-muted" id="pwd"><i class="bi bi-lock-fill"></i></span>
                        <input type="password" id="password" class="form-control" placeholder="密码" aria-label="密码"
                            aria-describedby="pwd" />
                        <span class="input-group-text">忘记密码?</span>
                    </div>
                    <div class="input-group mb-1">
                        <p class="fs-6 fw-bolder text-danger" id="error">账号或密码错误</p>
                    </div>
                    <div class="input-group mb-3 d-grid gap-2">
                        <button class="btn btn-primary rounded-pill" type="button" id="login">登录</button>
                    </div>
                    <!-- 使用栅格布局 将div占一行 -->
                    <div class="input-group mb-3 row">
                        <!-- 两个div各占一半 -->
                        <div class="col-6 text-center">
                            <a href="#" class="text-decoration-none">新用户注册</a>
                        </div>
                        <div class="col-6 text-center">
                            <a href="#" class="text-decoration-none">手机验证码登录</a>
                        </div>
                    </div>
                    <!-- 其他方式登录 -->
                    <div class="input-group mb-3 row">
                        <div class="col-12 text-muted text-center" style="margin-top: 30px;">
                            其他方式登录<i class="bi bi-chevron-right"></i>
                        </div>
                    </div>
                    <div class="input-group text-center mb-3 row">
                        <div class="col-12 text-center text-muted" style="font-size: 13px; margin-top: 50px;">
                            登录即表示同意平台<a style="color: rgb(0, 140, 255);">《隐私政策》</a>和<a
                                style="color: rgb(0, 140, 255);">《用户协议》</a>
                        </div>
                    </div>
                </div>
                <!-- 右侧二维码向右移动一侧 offset-md-1 -->
                <div class="col-md-4 offset-md-1">
                    <div class="row" style="font-size: 15px; color: #91A0B5; margin-left: 250px;">客服</div>
                    <div class="row mt-5">
                        <img src="./imgs/qrcode.jpg" class="rounded mx-auto d-block" alt="登录二维码"
                            style="width: 240px;height: 225px;">
                    </div>
                    <div class="row mt-4">
                        <div class="col-12 text-center text-muted">
                            使用表情包不扫码登录<i class="bi bi-coin"></i>

                        </div>
                    </div>
                </div>
            </div>
        </div>
    </div>
    <script type="module" src="./js/main.js"></script>
    <script src="./js/jquery.min.js"></script>
    <script>
        $(document).ready(function () {
            // 进入页面使用jQuery隐藏错误信息
            $("#error").hide();

            $("#login").click(function () {
                // jquery选择器选中用户名输入框 获取到用户输入数据 放到变量username
                let username = $("#username").val()
                // juqery选择器中用户密码输入框 获取用户输入密码 放到变量password
                let password = $("#password").val()
                // 使用jQuery发起异步请求 将账号密码发给后端 后端判定是否正确
                $.ajax({
                    url: "http://unicloud.codecore.cn/admin/login",
                    method: "POST",
                    data: JSON.stringify({ username: username, password: password }),
                    'contenType': 'application/json',
                    success: function (response) {
                        if (response.errCode == 0) {
                            // 登录成功
                            location.href = "./teacher/index.html"
                        } else {
                            // 登录失败
                            $("#error").show();
                        }
                    }
                })

            })
        })
    </script>
</body>

</html>